/*****************************************************************************************
 **  Author:COCO 2022
 *****************************************************************************************/
//此js文件是用来自定义扩展业务代码，可以扩展一些自定义页面或者重新配置生成的代码
import { h, resolveComponent } from 'vue'
import gridFooter from './custom_extend/Base_ProcessLineGridFooter'
let extension = {
  components: {
    //查询界面扩展组件
    gridHeader: '',
    gridBody: '',
    gridFooter: gridFooter,
    //新建、编辑弹出框扩展组件
    modelHeader: '',
    modelBody: {
      emits: ['parentCall'],
      render() {
        return [
          h(
            resolveComponent('el-alert'),
            {
              style: { 'margin-bottom': '5px' },
              'show-icon': true,
              type: 'success',
              closable: false,
              title:
                '上下拖动行顺序可以调整工序顺序。【工艺路线-工序列表】类型选择【工序】，则必输后面【工序】列，选择【工艺路线】，则必输后面【工艺路线】列',
            },
            ''
          ),
        ]
      },
    },
    modelFooter: '',
  },
  tableAction: '', //指定某张表的权限(这里填写表名,默认不用填写)
  buttons: { view: [], box: [], detail: [] }, //扩展的按钮
  methods: {
    //下面这些方法可以保留也可以删除
    onInit() {
      //框架初始化配置前，
      //示例：在按钮的最前面添加一个按钮
      //   this.buttons.unshift({  //也可以用push或者splice方法来修改buttons数组
      //     name: '按钮', //按钮名称
      //     icon: 'el-icon-document', //按钮图标vue2版本见iview文档icon，vue3版本见element ui文档icon(注意不是element puls文档)
      //     type: 'primary', //按钮样式vue2版本见iview文档button，vue3版本见element ui文档button
      //     onClick: function () {
      //       this.$Message.success('点击了按钮');
      //     }
      //   });

      //示例：设置修改新建、编辑弹出框字段标签的长度
      // this.boxOptions.labelWidth = 150;
      //显示序号(默认隐藏)
      this.single = true
      this.labelWidth = 120
      //this.tableHeight = (document.body.clientHeight-260)/2;
      this.tableMaxHeight = (document.body.clientHeight - 260) / 2
      //示例：设置修改新建、编辑弹出框字段标签的长度
      this.boxOptions.labelWidth = 120
      //显示序号(默认隐藏)
      this.columnIndex = true
      this.boxOptions.draggable = true
    },
    onInited() {
      //框架初始化配置后
      //如果要配置明细表,在此方法操作
      //this.detailOptions.columns.forEach(column=>{ });
      //注意：明细表操作需要写在onInited方法中
      //给明细表ProductName下拉框添加onChange事件
      this.detailOptions.columns.forEach((x) => {
        if (x.field == 'Process_Id') {
          x.onChange = (column, row, tableData) => {
            var param = {
              order: 'desc',
              page: 1,
              rows: 30,
              sort: 'CreateDate',
              wheres:
                '[{"name":"Process_Id","value":"' +
                column.Process_Id +
                '","displayType":"number"}]',
            }
            if (column.ProcessLineType == 'process') {
              this.http
                .post('/api/Base_Process/getPageData', param, true)
                .then((result) => {
                  column.SubmitWorkMatch = result.rows[0].SubmitWorkMatch
                })
            }
          }
        }
        if (x.field == 'ProcessLineType') {
          x.onChange = (column, row, tableData) => {
            if (column.ProcessLineType == 'processLine') {
              column.SubmitWorkMatch = ''
            }
          }
        }
      })

      this.detailOptions.columns.forEach((item) => {
        if (
          (item.field ==
            'ProcessLineDown_Id' ||
            item.field == 'IsShowCode1' ||
            item.field == 'IsShowCode2' ||
            item.field == 'SubmitWorkMatch')
        ) {
          item.hidden = true
        }
      })
    },
    searchBefore(param) {
      //界面查询前,可以给param.wheres添加查询参数
      //返回false，则不会执行查询
      return true
    },
    searchAfter(result) {
      //查询后，result返回的查询数据,可以在显示到表格前处理表格的值
      this.$nextTick(() => {
        this.$refs.gridFooter.rowClick(result[0], '工艺路线')
      })
      return true
    },
    addBefore(formData) {
      //新建保存前formData为对象，包括明细表，可以给给表单设置值，自己输出看formData的值
      formData.detailData.map((item, index) => {
        Object.assign(item, { Sequence: index + 1 })
      })
      return true
    },
    updateBefore(formData) {
      //编辑保存前formData为对象，包括明细表、删除行的Id
      formData.detailData.map((item, index) => {
        Object.assign(item, { Sequence: index + 1 })
      })
      return true
    },
    rowClick({ row, column, event }) {
      //查询界面点击行事件
      this.$refs.table.$refs.table.toggleRowSelection(row) //单击行时选中当前行;
      //调用Doc_Order1GridFooter.vue文件中(订单明细)的查询
      this.$refs.gridFooter.rowClick(row, '工艺路线')
    },
    modelOpenAfter(row) {
      //点击编辑、新建按钮弹出框后，可以在此处写逻辑，如，从后台获取数据
      //(1)判断是编辑还是新建操作： this.currentAction=='Add';
      //(2)给弹出框设置默认值
      //(3)this.editFormFields.字段='xxx';
      //如果需要给下拉框设置默认值，请遍历this.editFormOptions找到字段配置对应data属性的key值
      //看不懂就把输出看：console.log(this.editFormOptions)
      this.editFormOptions.forEach((item) => {
        item.forEach((x) => {
          //如果是编辑设置为只读
          if (x.field == 'ProcessLineCode') {
            //disabled是editFormOptions的动态属性，这里只能通过this.$set修改值
            //vue3版本改为设置：x.disabled=isEDIT
            x.placeholder = '请输入，忽略将自动生成'
          }
        })
      })
    },
  },
}
export default extension
